### Modul 1

# Arsitektur Zynq

### 1. Tujuan

- a. Memahami arsitektur Zynq.
- b. Memahami software Vivado 2016.4 dan membuat project baru.

#### 2. Materi

### a. Arsitektur Zynq

Zynq merupakan FPGA SoC. Block diagram arsitektur Zynq ditunjukan pada gambar 1. Pada Zynq terdapat Processing System (PS) dan Programmable Logic (PL). Pada PS terdapat processor dual core ARM Cortex-A9, sedangkan PL sendiri merupakan FPGA.



Gambar 1. Arsitektur Zynq

Pada PL, kita dapat membuat design menggunakan Verilog ataupun menggunakan IP core yang telah disediakan oleh Xilinx. Design pada PL dapat berkomunikasi dengan PS melalui beberapa interface seperti SGP, MGP, HP, dan ACP. Design yang dibuat pada PL harus compatible dengan standard AXI bus agar dapat berkomunikasi dengan PS.

#### b. Half Adder

Merupakan eleman penjumlahan yang paling kecil yang memiliki tabel kebenaran pada tabel 1.

| input |   | output |       |
|-------|---|--------|-------|
| а     | b | sum    | Carry |
| 0     | 0 | 0      | 0     |
| 0     | 1 | 1      | 0     |
| 1     | 0 | 1      | 0     |
| 1     | 1 | 0      | 1     |

Tabel 1. Tabel kebenaran half adder

Rangkaian half adder dapat dibuat menggunakan gerbang logika seperti pada gambar 2.



Gambar 2. Rangkaian half adder

## c. Full Adder

Merupakan eleman penjumlahan yang dibuat dari half adder yang memiliki tabel kebenaran sperti pada tabel 2.

| input |   |   | output |       |
|-------|---|---|--------|-------|
| а     | b | U | sum    | Carry |
| 0     | 0 | 0 | 0      | 0     |
| 0     | 0 | 1 | 1      | 0     |
| 0     | 1 | 0 | 1      | 0     |
| 0     | 1 | 1 | 0      | 1     |
| 1     | 0 | 0 | 1      | 0     |
| 1     | 0 | 1 | 0      | 1     |
| 1     | 1 | 0 | 0      | 1     |
| 1     | 1 | 1 | 1      | 1     |

Tabel 2. Tabel kebenaran full adder

Rangkaian full adder dapat dibuat dari komponen half adder dan sebuah gerbang OR seperti pada gambar 3.



Gambar 3. Rangkaian full adder

#### 3. Tutorial

Pada tutorial ini, kita akan membuat dan mensimulasikan full adder pada Vivado, kemudian mendownload file bitstream ke PL. Pada tutorial ini kita hanya akan memakai PL, sedangkan untuk PS akan digunakan pada tutorial berikutnya.

## a. Membuat project baru

1. Masuk ke menu File  $\rightarrow$  New Project  $\rightarrow$  Next.

2. Masukan Project name dan Project location.



3. Set Project type seperti gambar berikut.



4. Pilih chip Zynq yang sesuai dengan board ZYBO: xc7z010clg400-1



5. Klik Finish untuk membuat project baru.

## b. Membuat source code Verilog

1. Klik Add Sources pada Project Explorer, pilih Add or create design sources.



2. Klik Create File, untuk membuat file Verilog baru.



3. Buat modul baru dengan nama half adder.



4. Klik Yes pada tampilan berikut.



5. Buka file **half adder.v** dengan cara double klik.



#### c. Membuat modul half adder dan full adder

1. Masukkan kode Verilog ini untuk half adder.v.

```
in the state of the state
```

2. Buat source baru dengan nama **full adder.v**, kemudian buat kode berikut ini.

```
timescale 1ns / 1ps

module full_adder
(
    input wire a,
    input wire b,
    input wire c,
    output wire sum,
    output wire carry
);

wire sum_0, carry_0, carry_1;

half_adder half_adder_0
(
    .a(a),
    .b(b),
```

```
.sum(sum_0),
    .carry(carry_0)
);

half_adder half_adder_1
(
    .a(sum_0),
    .b(c),
    .sum(sum),
    .carry(carry_1)
);

assign carry = carry_0 | carry_1;
endmodule
```

### d. Membuat file testbench

1. Klik Add Sources pada Project Explorer, pilih Add or create simulation sources.



2. Klik Create File, untuk membuat file Verilog baru dengan nama full adder tb.v.



3. Buka file **full adder tb.v** dengan cara double klik.



4. Masukkan kode Verilog ini untuk **full adder tb.v**.

```
`timescale 1ns / 1ps

module full_adder_tb();
   localparam T = 10;

   reg a;
   reg b;
   reg c;
   wire sum;
```

```
wire carry;
    full_adder_0
        .a(a),
        .b(b),
        .c(c),
        .sum(sum),
        .carry(carry)
    );
    initial
    begin
        a = 0;
        b = 0;
        c = 0;
        #T;
        a = 0;
        b = 0;
        c = 1;
        #T;
        a = 0;
        b = 1;
        c = 0;
        #T;
        a = 0;
        b = 1;
        c = 1;
        #T;
        a = 1;
        b = 0;
        c = 0;
        #T;
        a = 1;
        b = 0;
        c = 1;
        #T;
        a = 1;
        b = 1;
        c = 0;
        #T;
        a = 1;
        b = 1;
        c = 1;
        #T;
    end
\verb"endmodule"
```

## e. Simulasi design pada Vivado

1. Pada Project Explorer, klik **Simulation Settings**. Pastikan top module nya adalah **full adder tb**.



2. Run simulation dengan cara klik, **Run Simulation** pada Project Explorer. Hasil simulasi seperti pada gambar berikut.



3. Save waveform dengan cara File  $\rightarrow$  Save Waveform Configuration As. Hasil simulasi full adder sebagai berikut.



f. Mapping pin ke I/O

1. Klik Add Sources pada Project Explorer, pilih Add or create constraints.



2. Add file **ZYBO** master.xdc.



3. Hubungkan pin switches ke input full adder, a, b, dan c.

```
##Switches
##IO_L19N_T3_VREF_35
set_property PACKAGE_PIN G15 [get_ports {a}]
set_property IOSTANDARD LVCMOS33 [get_ports {a}]

##IO_L24P_T3_34
set_property PACKAGE_PIN P15 [get_ports {b}]
set_property IOSTANDARD LVCMOS33 [get_ports {b}]

##IO_L4N_T0_34
set_property PACKAGE_PIN W13 [get_ports {c}]
set_property IOSTANDARD LVCMOS33 [get_ports {c}]
```

4. Hubungkan pin LED ke output full adder, sum dan carry.

```
##LEDs
##IO_L23P_T3_35
set_property PACKAGE_PIN M14 [get_ports {sum}]
set_property IOSTANDARD LVCMOS33 [get_ports {sum}]
#IO_L23N_T3_35
set_property PACKAGE_PIN M15 [get_ports {carry}]
set_property IOSTANDARD LVCMOS33 [get_ports {carry}]
```

5. Save file **ZYBO\_master.xdc** tersebut.

# g. Synthesis design pada Vivado

1. Pada Project Explorer, klik Run Synthesis, kemudian klik Yes.



2. Setelah synthesis selesai, pilih Run Implementation, kemudian klik Yes.



3. Setelah synthesis selesai, pilih Generate Bitstream.



4. Setelah bitstream digenerate, window berikut ini dapat di **close**.



# h. Upload ke board ZYBO

1. Pada Project Explorer, **Program and Debug**, pilih **Hardware Manager**, kemudian hubungkan board ZYBO ke development PC, dan nyalakan. Klik **Open target**  $\rightarrow$  **Auto connect**.



2. Progam device dengan cara klik **Program device** → **Program.** 



3. Hasil akhir dapat dilihat pada board dengan mengubah switch dan output pada LED.